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(57) Abstract 

An energy management system (12) and method is provided for energy users with large physical plants (14) which provides these 
energy users with a comprehensive understanding of the energy consumption of their physical plant (14) and with the ability to manage it 
in a way that makes sense for their business. The system (12) may include three-dimensional facilities navigation tools, powerful energy 
consumption analysis processes, TCP/IP communication capabilities and a World Wide Web (WWW)-based interface. The system (12) 
also includes a real-time data retrieval and dissemination process and system which permits real-time energy data to be communicated 
within the system (12). 
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ENERGY MANAGEMENT SYSTEM AND METHOD 

Background of the Invention 

This invention relates generally to a system and method for managing the use 
of energy and in particular to a system and method for automatically managing the use 
of energy for a commercial user. 

The problem of energy management and energy cost management has always 
been an issue for many commercial users who operate large physical plants (i.e., 
facilities and/or factories) because of the large amount of energy which is consumed by 
the facilities or factories. It is desirable to manage and analyze the energy 
consumption of the physical plant in order to reduce the total energy costs of the 
physical plant. The energy management process may involve many steps such as, for 
example, purchasing energy from another less expensive source or adjusting the energy 
usage of the facility to off-peak times when energy rates are lower. A conventional 
system for energy management may be a computer system housed in the basement of a 
facility or factory, that permits a person to view the energy usage of various equipment 
within that particular facility and makes changes to the energy usage based on 
information received at the computer system. 

The problem of energy management is especially complex for large entities, 
such as corporations, universities, municipalities, etc., which may have a physical plant 
with many different facilities or factories located at various different locations. With a 
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conventional energy management approach, each facility owned by the large entity 
may independently manage its own energy. Thus, for a large entity, there must be a 
conventional energy management system associated with each facility or factory, 
which greatly increases the overall cost of conventional energy management. In 
5 addition, each energy management system may use a slightly different data structure 
for the data being generated so that these multiple energy management systems cannot 
be easily integrated into a single energy management system for the entire physical 
plant. 

In most conventional systems, the task of energy management is separated from 
10 the task of facilities management. Thus, each facility generally has both an energy 
management system and a facilities management system. To reduce the costs of the 
management of the facility, it is desirable to integrate these two systems into a single 
system. 

Therefore, it is desirable to provide a single integrated energy and facilities 
15 management system which connects a physical plant with multiple, possibly 

geographically dispersed, facilities or factories together so that the task of energy and 
facilities management may be accomplished at a single central location. The single 
control location may be remote from all of the facilities. It is also desirable to provide 
an energy and facilities management system which provides the user of the system 
20 with a simulation of the facilities being managed so that the user may view the 

physical plant without actually being at the site. Thus, it is desirable to provide an 
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energy management system and method which provides the above advantages and 
avoids the problems with the conventional systems, and it is to this end that the present 
. invention is directed. 

Summary of the Invention 

5 In accordance with the invention, an energy and facilities management system 

is provided for energy users with large physical plants which provides these energy 
users with a comprehensive understanding of the energy consumption of their physical 
plant and with the ability to manage it in a way that makes sense for their business. 
The system accomplishes this goal by using, for example, three dimensional facilities 

10 navigation tools, powerful energy consumption analysis processes, TCP/IP 

communication capabilities and a World Wide Web (WWW)-based interface. The 
system therefore present large amounts of real-time energy data to users in a clear, 
concise and useful format. The system permits the user to alter energy consumption 
patterns and/or procure power more intelligently in order to save money. To 

15 accomplish the real-time movement of the large amounts of energy data, the system 
may include a robust, scaleable real-time data server component and a scaleable 
database which allows for flexibility and ease of integration between products and 
modules. The real-time server permits the system to provide a web-based interface 
which allows multiple users from a variety of locations to access important energy 

20 information at a much lower cost versus existing energy management systems. 
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The system, in accordance with the invention, may be divided into one or more 
sub-systems which manage different portions of the physical plant of the entity. For 
example, there may be an energy manager, a facility navigator, a facility manager and 
an alarm manager in a preferred embodiment of the invention. Each of these sub- 
systems performs operations which permit an employee of the entity to control and 
manage its facilities including its energy consumption. For example, the energy 
manager may track and/or analyze energy usage data, the navigator may permit the 
user to visualize each facility through a simulation, the facility manager may analyze 
control problems, and the alarm manager may notify the user of alarms and response to 
alarms as appropriate. Each of these sub-systems work together to provide an 
integrated energy and facility management system. 

In accordance with another aspect of the invention, a system and method for 
moving data between the various sub-systems within the energy management system is 
disclosed. The data moving method concatenates data at one or more sources such that 
the total amount of data being communicated between the sub-systems is reduced. 

Thus, in accordance with one aspect of the invention, a system for managing 
the facilities and the energy consumption of a physical plant is provided in which the 
physical plant has one or more facilities and buildings in which each building and 
facility has one or more devices which operate and consume energy. To accomplish 
the management of the physical plant, the system may gather information about the 
energy consumption and operation of each device in the physical plant and control the 
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facilities, buildings and devices in the physical plant, based on the energy consumption 
and operating information for each device, by communicating the energy consumption 
and operating data in real-time between the devices and the energy and facility 
management apparatus. The system may also include a user interface for requesting 
energy consumption and operation data about one or more devices and for viewing the 
energy consumption and operation data about the physical plant. A method for energy 
and facility management is also provided. 

In accordance with another aspect of the invention, an apparatus for managing 
the facilities and energy consumption of a physical plant including one or more pieces 
of equipment and one or more facilities is provided in which data is received from each 
facility corresponding to building control signals, energy usage signals and weather 
data and external data is received corresponding to energy rates and weather forecasts. 
The apparatus may generate energy management data for the facilities and equipment 
in the physical plant based on the facility data and the external data. It may also 
generate a representation of each facility in the physical plant so that a user navigates 
through each facility. The apparatus may also generate facility management data to 
help a user of the apparatus control the facilities of the physical plant. 

In accordance with another aspect of the invention, a system for 
communicating data in real-time between an energy and facility management system 
and the devices of a physical plant is provided in which a plurality of devices in the 
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physical plant operate and consume energy. The system may include a device interface 
connected to one or more of the devices for gathering energy consumption and 
operation data about the one or more devices connected to the device interface and a 
server connected to the device interface for storing the energy consumption and 
5 operation data for each device in the physical plant. The system may further include a 
plurality of client applications which request to receive energy consumption and 
operation data about one or more devices in the physical plant from the server, and a 
concentrator connected to one or more of the client applications. The concentrator may 
analyze the requests for data from the client applications, combine requests for energy 
10 consumption and operation data about a particular device into a single combined 

request, communicate the single combined request to the server, and route the energy 
consumption and operating data about the particular device received from the server to 
each client application which requests the energy consumption and operation data 
about that particular device. 

15 Brief Description of the Drawings 

Figure 1 is a diagram illustrating a geographically diverse enterprise having one 
more facilities and an integrated energy and facilities management system; 

Figure 2 is a block diagram illustrating an energy and facility management 
system in accordance with the invention; 
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Figure 3 is a diagram illustrating the data flow through the energy and facility 
management system shown in Figure 2; 

Figure 4 is a diagram illustrating more details of the real-time data topology of 
the energy and facility management system of Figure 2; 

5 Figure 5 is a flowchart illustrating a method for updating data in real-time in 

accordance with the invention; 

Figure 6 is a flowchart illustrating a method for registering a client and with a 
concentrator device in accordance with the invention; 

Figure 7 is a flowchart illustrating the operation of the client and concentrator 
10 device in accordance with the invention; and 

Figure 8 is a diagram illustrating the real-time data structures for the server in 
accordance with the invention. 

Detailed Description of a Preferred Embodiment 

The invention is particularly applicable to an energy and facility management 
15 system for an energy user having a widely dispersed enterprise with widely dispersed 
energy consuming factories or facilities. The energy and facility management system 
may use a public global communications network known as the Internet/Intranet to 
communicate data between the elements of the system. It is in this context that the 
invention will be described. It will be appreciated, however, that the system and 
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method in accordance with the invention has greater utility, such as to other smaller, 
less complex physical plants and may use a variety of communications systems, 
including a private network, to communicate the data. 

Figure 1 is a block diagram illustrating a physical plant 10 of a large entity 
5 which may be controlled and managed by a central energy and facilities management 
system 12 in accordance with the invention. As shown, the physical plant of the entity 
may include one or more facilities 14 (Facility #1, Facility #2, Facility #3 and Facility 
#N) each of which consumes power and has facilities management requirements. In 
this example, these facilities may be located in widely disparate geographic locations, 

10 such as Palo Alto, California, Los Angeles, California, New York and Texas. It should 
be noted that the invention, however, is not limited to any particular number of 
facilities or the locations of those facilities since the system may also be used for an 
entity with just a few facilities in the same geographic location. As described above, it 
is desirable to be able to control and manage the energy consumption and other 

15 facilities problems from a single centralized location. 

To provide a centralized energy and facilities management system, the system 
12 may be interconnected to the facilities 14 by any conventional communications 
systems 16. In a preferred embodiment, the system 12 and the facilities 14 may be 
interconnected by the Internet/Intranet. The communications system permit data to be 
20 communicated between the facilities 14 and the energy and facilities management 
system 12 in real-time. To provide an interface between the energy and facilities 



8 



WO 00/17984 



PCT/US99/21787 



management system 12 and each facility 14, each facility may include an energy 
management device (EM) for communicating data between the energy and facilities 
.management system 12 and the facility 14 as described below in more detail. In 
particular, the combination of the system 12 and the EM devices permit real-time data 
5 to be communicated between the system 12 and the facilities 14. In accordance with 
the invention, a user at the energy and facility management system 12 may control and 
manage each of the facilities without necessarily being on-site at any of the facilities. 
The energy and facilities management system 12 may permit, for example, the energy 
usage of each facility to be monitored and an alarm sounded if a predetermined 

10 condition occurs. Because the energy and facility management system 12 is connected 
to the facilities 14 by a communications system 16, the energy and facility 
management system 12 may be located at any geographic location while providing 
complete control and management of all of the facilities in the physical plant 10. In 
addition to the facilities 14, one or more user terminals 17 may also be connected to the 

15 system 12 by the communications system 16, which may preferably be the 

Internet/Intranet. These terminals 17 may be located at any location where access to 
the communications system 1 6 is available. For example, a manager may access real- 
time energy data from a facility in Singapore while in New York. In addition, there 
may be multiple people at various different locations accessing different or the same 

20 energy data at the same time due to the real-time data retrieval and dissemination 

system as described below in more detail. Thus, anyone in the entity may access any 
energy data about the physical plant at any time. The actual data displayed to each 
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user may be customized based on the user's needs so that each user may receive 
different data or the same data presented in a different way. For example, a CFO may 
receive a different set of data than an energy manager. Now, the energy and facilities 
management system 12 will be described in more detail. 

5 Figure 2 is a block diagram of the energy and facilities management system 12 

in accordance with the invention which provides energy and facilities management 
capabilities for a physical plant. The system may include one or more internal data 
sources 22, one or more external data sources 24 and an energy and facility 
management apparatus 26. The internal data sources 22 may be devices internal to the 

10 facility which generate data about the facility used for energy and/or facility 

management. For example, the internal data sources may include a building control 
gateway 28 which provides one or two-way data communications between the existing 
controls of the facility and the apparatus 26, a meter gateway 30 which provides data to 
the apparatus 26 about the energy usage of the facility, and a weather gateway 32 

15 which provides various weather data, such as humidity or temperature, to the apparatus 
26. The external data sources may be data sources which are outside of the particular 
facility, but which also provide data which is useful for energy and facility 
management. For example, the external data sources may include a market energy 
rates source 34 which contains data about the energy costs for various energy providers 

20 and a weather data source 36 for providing future weather forecasts for each facility. 
Using the various data from the internal and external data sources 22, 24, the energy 
and facility management apparatus 26 may, for example, track energy usage or change 
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energy usage patterns based on the forecast weather or based on a less expensive 
energy provider. The various energy management processes will be described below 
in more detail. 

The apparatus 26 may be a computer system which executes a plurality of 
different software packages which implement the functions of the system which are 
described below. As shown, the apparatus 26 may include an energy manager 40, a 
facility navigator 42, a facility manager 44 and an alarm manager 46. Thus, the 
apparatus may be divided up into four components and a customer may select features 
from some or all of these components to create a product bundle that most closely fits 
their needs. The invention, however, is not limited to an apparatus which includes all 
of these components and thus the invention may include only one or more of the 
components. Each of these components may be implemented as a piece of software 
being executed by a server computer, for example. Each of these components will now 
be described in more detail. 

The energy manager 40 gathers energy usage data and permits users of the 
system to view and analyze energy usage over any combination of facilities or time 
periods. The energy manager may permit the user to diagnose energy usage problems 
and develop strategies to reduce energy costs by optimizing responses to queries by the 
user based on the time of day, the current energy rate and environmental conditions. 
The energy manager may receive data from a variety of sources, such as utility meters 
in the facility. The energy manager may perform a variety of functions, such as 
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tracking energy usage, analyzing energy usage by analyzing historical energy usage 
data or analyzing energy load aggregation data, energy rate analyzing, energy usage 
forecasting based on various data such as forecast weather conditions, power 
procurement analyzing, such as generating a request for purchase (RFP), analyzing the 
5 energy usage of different sites and comparing the sites to each other and alarm 

signaling. In more detail, the usage tracking may include monitoring and generating 
trends for real-time energy usage of each facility in various energy units, such as 
kilowatts (KW), kilowatt hours (KWH), or British thermal units (BTUs). The usage 
tracking may also include aggregating energy loads for the various facilities and 

10 retrieving and comparing historical energy usage with real-time energy usage. The 
energy usage analysis may include an energy load shape analysis, a peak energy 
demand determination, an identification to determine the largest energy consumers 
and/or the consumers who use the energy during the peak energy usage time, and a 
determination of energy load and energy power factors as is well known. The rate 

15 analysis may include determining energy costs based on existing rates on a per meter, 
per building, per site, per cost center or corporate wide basis, an energy load scenario 
builder in which different energy rates scenarios may be played out to determine the 
best rate for the entity compared to a base scenario, generating energy bills, and 
viewing real-time and historical energy demand levels on a per meter, per building, per 

20 site, per cost center or corporate wide basis. The usage forecasting may use weather 
data to forecast a future day, week, month or year's energy usage. An alarm signaling 
function may generate an alarm signal when certain conditions occur, such as energy 
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load peaks, power spikes, surges, sags and deviations from an acceptable signal quality 
and keep track of the total number of alarms. Now, the facility navigator 42 will be 
described in more detail. 

The facility navigator 42 may permit any user of the energy and facility 
5 management apparatus 26 who is connected to the apparatus by the communications 
system 16 (see Figure 1) to view real-time two-dimensional or three-dimensional 
representations of any facility in the physical plant, to configure a particular site, to 
analyze and locate energy or facility management problems at a site, or to generate a 
report. In particular, the facility navigator may permit a user to navigate and analyze 

10 problems at multiple sites using advanced 2-D and 3-D visualization tools. In more 
detail, the two-dimensional navigator may generate graphical representations of the 
details of the facilities, sites and the like to permit the user to navigate through all of 
the sites, through a site to a specific building on a site, or through a particular building 
on a site. The navigator may also generate visual representations of an event, such as 

15 an alarm or excessive power usage, so that the user may see these events when they are 
navigating through the site or building. As an example, the navigator may display a 
particular building as red indicating that the building is using too much power based on 
past history and the user of the navigator will see the red building and may investigate 
the problem. The navigator may also permit the user to look at individual systems in a 

20 building, such as HVAC system or equipment components, to analyze a problem. The 
three-dimensional navigator may perform similar functions as the two-dimensional 
navigator, but in three-dimensions. The site configuration functions permits the user of 
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the apparatus to customize , create or update a particular site to add various 
information. For example, the site configuration may permit the user to generate a site 
map for a newly opened facility which is going to be managed by the apparatus 26. 

The facility manager 44 may integrate existing building control systems to 
5 permit the user of the apparatus to have access to data from the existing building 
control systems as well as newly installed systems so that the apparatus 26 may be 
easily integrated with existing systems. The facility manager may perform data 
monitoring and collection processes which may include monitoring, trending and 
archiving data (i.e., temperatures, pressures, flows, levels, set points and states) about 

10 existing systems, such as HVAC systems, boilers, chillers, cooling towers, generators, 
compressors, motors and pumps and lighting. The facility manager may also monitor 
and trend (i.e., determine a trend and how the particular quantity will act in the future) 
environmental conditions, such as lighting, interior and exterior temperatures, relative 
humidity, solar radiation and the like. The facility manager may also monitor and 

1 5 display peak facility operating periods. The facility manager may also analyze 

equipment efficiencies under partial and full load, develop operating efficiency load 
profiles, track operating hours and benchmark load profiles against capacity ratings. 
The facility manager may also optimize the existing systems by, for example, 
balancing HVAC operating times to meet building use periods and environmental 

20 changes, and optimize existing equipment's usage. The facility manager may also 

control the existing systems and devices and initiate soft starts, hard starts and stops of 
the equipment, program control set-points and provide a manual override of the 
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systems and equipment. 

The alarm manager 46 handles any alarms generated at any point in the 
apparatus 26 or physical plant 10. For example, it may collect alarm information from 
the energy manager or the facility manager and then prioritize these alarms. The alarm 
5 manager may also notify the appropriate people, by various different methods, such as 
e-mail, fax or pager, who need to respond to a particular alarm. Now, the flow of data 
through the energy management system in accordance with the invention will be 
described with reference to Figure 3. 

Figure 3 is a diagram illustrating an example of a physical plant 50 of a 
10 commercial user which may include one or more buildings 52, 54, 56, 58 and 
additional equipment and devices (D) which may be controlled by the energy 
management system in accordance with the invention. The energy management 
system may include one or more computer systems 60, 62, 64 which may be server 
computers which interconnect the various buildings and equipment of the physical 
15 plant for purposes of controlling and managing the buildings and the equipment. In the 
example shown, the energy management system may include the central server 60 
which receives data and information from the other servers, the buildings and the 
equipment. The invention, however, is not limited to a energy management system 
with a central server. 

20 At each building, a user executing a client application on a personal computer, 

for example, may query one of the servers and receive data about some portions of the 

15 



WO 00/17984 



PCT/US99/21787 



entity's physical plant. In the example shown in Figure 3, each client application 
requesting data about the enterprise may be represented by a client object in an object 
oriented programming language. Therefore, in accordance with the invention, in order 
to provide information to a particular client application, the client object corresponding 
5 to the client application may be modified and then the client application may read the 
modified client object. For example, in building 54, a first client application/object 66 
and a second client application/object 68 may access information about the physical 
plant. In the embodiment shown, the client applications may be client software 
applications being executed on a computer system within the building which access 

10 data from the servers. In the preferred embodiment, the client applications/objects may 
be Internet/Intranet browser software applications which access the servers over the 
Internet/Intranet to communicate data and commands to the servers. For locations, 
buildings or sites in which more than one client application is being executed, the 
energy management system may include a data concentrator (C) which attempts to 

15 reduce the data traffic between the client application and the servers by combining 

requests from the client applications into a single request. For example, if both client 
applications are requesting the same updated data about a particular piece of 
equipment, the concentrator may generate a single request for the data and then 
communicate that updated data to each client application once the updated data is 

20 received by the concentrator. 

The equipment and devices (D) may be connected to the servers 60 - 64 by a 
gateway (G) which acts as an interface between the device D and the servers. In 
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particular, the gateway may be a software application which interprets the particular 
device or equipment's signals into standardized data which may then be stored by the 
servers. Therefore, each gateway G may be somewhat unique since it converts signals 
from a particular device D into a standard format. 

In operation, the devices D may generate data about the operation of the device 
or its energy usage and pass the data to the gateway which forwards it on to the server 
which stores the data. When a client application requests data about a device, the 
request is passed to the concentrator associated with the application which filters out 
any duplicate requests. Then, when a concentrator requests data about the device, the 
server may communicate the data to the concentrator which passes the data onto the 
appropriate client application. A similar process may occur to update data about a 
device. To accomplish the real-time retrieval and dissemination of data, a unique 
address is assigned to each device and client application in the real-time data retrieval 
and dissemination system as will now be described. 

Figure 4 illustrates more details of a real-time data retrieval and dissemination 
system 100 in accordance with the invention. In a preferred embodiment, the real-time 
data retrieval and dissemination system 100 may be implemented as a sophisticated 
software system containing a plurality of software applications which can perform 
various energy and facility management tasks. For example, the system 100 may 
remotely interface to various data acquisition and control systems over existing data 
networks (i.e., an internal computer network or the Internet/Intranet) thereby 



17 



WO 00/17984 



PCT/US99/21787 



eliminating the need for proprietary, expensive cabling to remotely locate a control 
system user-interface software application which permits a user to control and manage 
the entire physical plant of an organization from one location. In addition, because the 
system 100 interfaces to and consolidates the data from a variety of different systems 
5 having possible different data protocols into a central data server, a user of the system 
may utilize a common workstation to access and combine the functionality of different 
control systems from the same location using the same software. As with the 
equipment and physical plant which may be distributed over a large geographic area, 
the client software applications, which permit access to the data, may also be located 

10 anywhere within the span of the data network. This is especially advantageous since 
the number and type of client applications requesting for real-time information will 
grow significantly in the future, as this information becomes integral in optimizing the 
asset utilization of the enterprise. This permits the system to be scaleable and 
accommodate future expansion of the physical plant. It also permits the person 

15 controlling the physical plant to access data about the physical plant from any location. 
It also permits other people in the organization, such as the chief financial officer, to 
access data about the physical plant from his desktop computer which has a browser. 
In the example shown, the system 100 may include a central server computer 102, one 
or more client personal computers 104, 106, 108, one or more gateways 110, 112, 1 14, 

20 116 which connect one or more devices 1 18, 120, 122, 124, 126 to the server 102. 
Each of these will now be described in more detail. 
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The data gateways 110, 112, 114, 116 may be stand-alone software application 
modules that interface with the devices to perform data acquisition and to control the 
devices. As shown, multiple control systems or data collection devices of different 
types may be supported by a single data gateway. The communication medium 
5 between the gateway and the data collection device may vary. The data gateways may 
also be connected to a second data network to permit the gateway to communicate data 
with the server 102 to perform various functions, such as exchanging collected data or 
forwarding control commands from the energy management system to individual 
devices for execution. Each gateway may also include a configuration system 127 for 
10 configuring the gateway to a particular device. Now, the server 102 will be described 
in more detail. 

The server 102 is the controller for the real-time data retrieval and 
dissemination system. The server may be implemented as an individual software 
process executing on a single computer or as several software processes being executed 

15 on a network of multiple computer systems. In either case, the configuration of the 

server is transparent to the client software application being executed by the client PCs. 
The distributed server architecture with multiple servers executing various pieces of 
software may be especially well suited for scaling up the energy management system 
to handle very large applications of real-time data without affecting any development 

20 within the client application. In accordance with the invention, the server may execute 
software applications which implement the various sub-systems described above with 
reference to Figure 2. The server 102 may include a real-time database (Rtdb) 128 and 
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a configuration database 129 which communicate with each other. The Rtdb may 
receive data from the gateways, issue commands to the devices, and disseminate data 
to the client PCs 104-108. The configuration database 129 may receive configuration 
data from a gateway for a particular device and forward updated configuration data to a 
5 device and gateway. More detail about the operation of the server will be described 
below. 

Each client PC 104, 106 or 108 may include one or more client objects 130, 
132, 134 which are connected to a concentrator 136. As described above, the client 
objects, which may be software applications being executed by the client PC, such as a 

10 Internet/Intranet browser, may generate requests for data from the server 102 which the 
concentrator 136 may combine together if possible. The concentrator 136 thus may act 
as a data traffic controller to prevent the client objects from overloading the server 102 
with duplicate requests. The concentrator, therefore, reduces the data traffic flow 
between the server 102 and each PC. The client application may consist of one or 

15 more stand-alone software application programs or modules that can communicate 

independently to the server 102 to receive real-time data updates of data element status 
changes which are displayed visually for the client in a variety of ways, such as using a 
web browser. Thus, data is automatically updated for each client application as will 
be described in more detail below. Now, the flow of changed data through the real- 

20 time retrieval and dissemination system 100 will be described to better understand the 
operation of the system. 



20 



WO 00/17984 



PCT/US99/21787 



When a data change occurs on a device 1 18 - 126, a data gateway 110-116 
attached to the device may detect or be signaled of the data change depending on the 
capabilities of the device. Once the gateway receives the changed data, it may 
preprocess the data to standardize it for the energy management system and 
5 communicate it onto the Rtdb server 102. Upon arrival of the changed data at the Rtdb 
server , the Rtdb server checks an update list to determine which concentrators 136 are 
currently registered to receive data updates for this device. The current list of 
concentrators which receive the updated data for a particular device changes in real- 
time based on what data each concentrator is currently requesting or what data is being 
10 currently displayed by each client PC. 

Once the list of registered concentrators is determined, the Rtdb server may 
send the updated data to each concentrator 136. When a data update is received by a 
concentrator, the concentrator may in turn check a local list to see which client 
applications/objects 130- 134 attached to the particular concentrator are registered to 

1 5 receive the particular data updates. Next, the client concentrator may send the data 
update to each individual client application which updates its display based on the 
updated data. The client concentrator 136 therefore optimizes the efficiency of the data 
communication network by concentrating identical point data update registrations from 
multiple client applications/objects into a single request for data from the Rtdb server. 

20 Therefore, data requests by multiple client applications/objects may be serviced by a 
single data point update message from the Rtdb server which may be referred to as a 
point concentration process. 
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The point concentration process extends itself beyond the client objects to the 
Rtdb server 102 so that the server may act as a hub for all points (devices) that it 
services from its attached gateways, but in addition act as the hub for points from other 
Gateways attached to other Rtdb servers. Therefore, any client application/object that 
5 needs real-time updated information from any Gateway will receive that data from a 
local Rtdb server, who in turn is responsible for obtaining that information from other 
Rtdb servers, if necessary. To accomplish this, each server 102 may be viewed as just 
another concentrator to each "remote" Rtdb server. In other words, for data requested 
from another server, each server may concentrate multiple data requests for 
10 concentrators and client applications attached to it into a few data requests to reduce 

data traffic. Thus, the Rtdb server exhibits the same network optimization strategies as 
the client concentrator objects by concentrating identical point update registrations 
from multiple concentrators into a single registration to the remote Rtdb server. 

Throughout the system 100, registrations (requests) for real-time point (device) 
15 updates are initiated by client applications/objects by specifying a unique machine 

identifier and a unique point identifier combination for each device/point of interest to 
its associated concentrator. Thus, each server (machine identification) and 
device/point (point identification) has a unique address so that data may be efficiently 
routed through the communications network. For example, a client application 
20 attached to server A may request data from a device B by issuing a command 

indicating that A requests data about B so that the command contains the necessary 
addresses used by the concentrator and other server to route the data about device B to 
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the client application attached to server A. The concentrator then registers these 
points, if not already registered, with a local Rtdb server. Based on the machine 
identifier associated with each registered point, the Rtdb server can then pass a 
registration onto another Rtdb server if necessary, again, only if this point has not 
5 already been registered with that Rtdb server. This system of concentrating and 
forwarding point registrations lends itself to very simplistic administration because 
each Rtdb server requires no advance knowledge of other Rtdb servers anywhere else 
in the world as the machine identifier contains all of the information required to locate 
a Rtdb server. For example, the machine identifier may be composed of a unique 
10 TCP/IP address, a unique Uniform Resource Locator (URL), or a unique Domain 
Name Service (DNS) name which permits each Rtdb server to be individually 
identified. This process also naturally lends itself to scale up to handle very large real- 
time data applications. 

In summary, to accomplish the real-time data retrieval and dissemination in 
15 accordance with the invention, each client application/object is given a unique address, 
such as that contained in a MachinelD variable and each point or device is given a 
unique address, such as that contained in a PtID variable. Thus, for any data request or 
any update of existing data, there is an associated PtID or MachinelD variable which 
permits the system to rapidly communicate the data only to the clients which need the 
20 information. Now, the operation of the server during a point data update will be 
described. 
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Figure 5 is a flowchart illustrating a method 150 for point data updating at the 
server in accordance with the invention. In step 152, a gateway attached to the 
device/point with updated data call a Rtdb.UpdatePoint software subroutine which 
stores values for various variables, such as a machine identification (MachinelD), a 
5 point identification (PtID), a value of the changed data (Value), a date and time of the 
data change (DATETIME) and a status of the point/device at the time of the change 
(status) and passes the values in the variables onto the server. The server, in step 154, 
then fetches the updated data using the values contained within the subroutine 
variables from the gateway and stores the values in temporary storage while an 
1 0 authentication process occurs. 

In the next series of steps, the server authenticates the data update prior to 
distributing the data update values to other servers and/or clients. Thus, in step 156, 
the server determines whether the gateway is marked as running (i.e., Whether the 
server is aware of any problem with the gateway) when the update data subroutine is 

1 5 invoked. If the server detects that the gateway is not running, the data update process 
ends and no data update is completed. If the gateway is running, then in step 158, the 
server checks its data records to determine if the point with a data update is actually 
known to the server since the server maintains a list of the points which are connected 
to it. If the point is unknown, the method ends and no data update is completed. If the 

20 point is known to the server, then the server determines if the updated data from the 
known point has the proper data type in step 160. If the data type is not correct, the 
method ends and no data update is completed. Thus, in steps 156 - 160, the server may 
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authenticate a point data update prior to distributing the data update in order to reduce 
incorrect data within the system. Thus, each server attached to each point may act as a 
filter for updated data from that point. 

Next ? in step 162, the server updates various variables in a real-time 
5 (Rtdb)database in the server to reflect the updated data values. In particular, the server 
may update the values of a Rtdb. Value variable containing the new updated value of 
the point data, a Rtdb.Timestamp variable containing the time and date information 
about when the data as updated, and a Rtdb. Status variable containing information 
about the status of the point when the data update occurred. In the next series of steps, 
10 the server may determine the appropriate one or more other servers or concentrators to 
which the updated point data may be communicated. This process may be referred to 
as a Point Hot Link Manager shown diagramatically as step 164 in the flowchart. 

The Point Hot Link Manager process starts at step 166 in which the server 
determines, based on a list maintained in the server, which clients may be 

15 linked/registered to the particular point which has updated data. If there are no known 
clients which are registered to receive the updated data, the method ends and the 
updated data is being retained in the server until a client requests the data. In step 168, 
the server may determine, from its internal list, whether the particular client is another 
Rtdb server, a concentrator or something else based on the Machine ID variable. If the 

20 client is not another Rtdb server or a concentrator, the method ends. If the client is 
another server or a concentrator, then in step 1 70, the server may retrieve a pointer to 
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the particular client's interface from an internal file moniker. Next, in step 172, the 
server may call an Object. UpdatePoint subroutine which updates various variables, 
which are described above, in a data structure which is then communicated to the 
client. In this example shown, a MachinelD variable, a PtID variable, a Rtdb. Value 
5 variable, a Rtdb.Timestamp variable and a Rtdb. Status variable are updated to reflect 
the change in the point data. The calling of the subroutine thus updates the values for 
the particular client as identified by the MachinelD variable value so that client 
automatically receives the updated data anytime an update occurs. 

Next, in step 174, the server determines if there are any more clients who are 
10 registered to receive the updated data. If there are additional clients who are registered 
to receive the updated data, the method loops back to step 168 and repeats steps 168 - 
172 to update the data for the next client. Once all of the clients who are registered to 
receive data updates for the particular point are accounted for, the method ends. In this 
manner, for each point data update, the server may perform some authentication of the 
15 updated data and then proceed to distribute the updated data only to those clients which 
are registered with the server using the unique addresses as described above. In this 
manner, the method reduces the amount of data traffic over the communications 
network. Now, a method by which each client application/object may register itself to 
receive data updates from a particular point will be described. 

20 Figure 6 is a flowchart illustrating a method 180 by which a particular client 

application may become registered to receive data updates from a particular 
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point/device. In step 182, the client application may identify the points from which the 
client application wants to receive data. In particular, the client application may build 
an IPointsCollection data structure containing a collection of the IPointData objects 
that identify the one or more data points about which the client is interested in 
5 receiving data. The data structure may contain a plurality of data structure of the form 
"MachineName::point name". For example, the user of client application A may be 
currently viewing the data regarding device/point B and therefore, the client 
application will enter a data structure of the form "A::B" indicating that the particular 
client application wants to receive data updates about device B. This data structure 
10 may be maintained until the user is no longer viewing the data from device B. Next, in 
step 1 84, the client application may call a subroutine to register the request for the data 
from the particular point with the concentrator connected to the client application. In 
the example shown, the subroutine may be called with the command 
Concentrator.RegisterPoints(IPointsDataCollection **pPoints). 

15 In the next series of steps, the concentrator may register the point data requests 

and determine if a request has already been made for the same point data by either the 
same client application or another client application connected to the same 
concentrator. This permits the concentrator to reduce the total data traffic by 
concentrating requests for data from a particular point by one or more clients into a 

20 single data request to the server. The concentrator then distributes the point data to the 
appropriate client applications. For each point name in the points collection, the 
concentrator may attempt to identify the point in step 186. In step 188, the 
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concentrator determines if the point has already been identified (i.e., has the 
concentrator already previously received data or data requests about the point). If the 
point has not been previously identified, then the concentrator may perform a series of 
steps to request the data for the particular point from an attached server. Thus, in steps 
5 190, 192 and 194, the concentrator may generate a RtdbRegistrar.GetStaticPointData 
command to get any static data about the point, a RtdbRegistrar.GetDynamicPointData 
command to obtain any dynamic data about the point, and a RtdbRegistrar. Subscribe 
command indicating that the concentrator is registered with the server for the particular 
point so that the concentrator should automatically receive any updates to the point 
10 data as described above. 

If the point has already been previously identified (i.e., the concentrator already 
has the data about the point and any updates), then in step 196, the concentrator may 
fill in various variables in a data structure with the values for the data for the particular 
point. In the example shown, the MachinelD, PtID, Value, Timestamp, 

15 ControlCmdTimeout and Status variables may be filled in to provide the data to the 
particular client. Next, in step 198, the concentrator determines if there are any other 
point names to identify and loops back to step 188 if there are additional point names 
to identify. If there are no other point names to identify, the method is completed. In 
summary, this method permits a client application to register its need for data about a 

20 particular point and permits the concentrator to avoid unnecessary data traffic by 
combining requests about data from the same point by different clients. Now, a 
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method by which the concentrator receives updated data from a server in accordance 
with the invention will be described. 

Figure 7 is a flowchart illustrating a method 210 by which a concentrator 
receives updated data for a point from a server in accordance with the invention. In 
5 step 212, the server calls a subroutine to populate a data structure with the updated 
data. In the example shown, the subroutine called is "Concentrator.UpdatePoint" and 
it updates values in a MachinelD variable, a PtID variable, a Value variable, a 
Timestamp variable and a Status variable. Then, in step 214, for each PointsCollection 
containing the correct MachinelD value and PtID value, the server may update the 

10 values of the point data by updating (step 216), for example, a PointData. Value, a 

PointData.Timestamp and a PointData. Status variable. Next, to provide the update to 
the various clients registered to receive it, the server may call a subroutine, such as 
PointsDataCollection.OnUpdatePoint, in step 218, to update the MachinelD, PtID, 
Value, Timestamp and Status values in the appropriate variables. Next, in step 220, 

1 5 the concentrator determines if there are any other PointsCollections which contain the 
same MachinelD and PtID values as the current updated data. If there are no other 
PointsCollections with the same MachinelD and PtID values, the method is completed. 
If there are additional PointsCollections data structure containing the same MachinelD 
and PtID values, the method loops back to step 216 to handle the other 

20 PointsCollections. In this manner, when new updated data for a particular point is 
received by the concentrator, the concentrator then goes through a process to identify 
clients attached to it which have registered to receive the updated data and passes the 

29 



WO 00/17984 



PCT/US99/21787 



updated data onto only the clients which are registered to receive the updated data. 
Now, an example of the data structures which are utilized by the server in accordance 
with the invention will be described. 

Figure 8 is a diagram illustrating examples of the various data structures 
5 utilized by the server in accordance with the invention. It should be noted that this is 
only an example of the data structures and the invention is not limited to any particular 
data structure. As shown, each site of a physical plant may have a site data structure 
230 associated with it which may contain a description variable containing a 
description of the particular site and a SitelD variable containing a unique address for 

10 the site. Each location (i.e., building or other location) within a site may have a 

location data structure 232 which may include a Tag variable containing a unique short 
name for the location, a LocationID variable containing a unique address for each 
location, the SitelD variable as described above identifying the site on which the 
location exists, a description variable containing a description of the locations, such as 

15 building 42, a NumFloors variable indicating the number of floors in the building, a 
SqFeet variable indicating the square footage of the location, a TextureType variable 
indicating the texture that may be used to render the building during the facility 
navigation, a DemandThreshold variable indicating when an alarm is generated for a 
particular reading, and a Group variable indicating a group to which the location 

20 belongs. Each data acquisition may have a system data structure 234 associated with it 
which contains a Description variable containing a description of the particular data 
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acquisition, a SystemID variable containing a unique address for each system, and a 
LocationID variable, as described above identifying the location of the system. 

For each point/device, there may be a StaticPointData data structure 236, a 
DynamicPointData data structure 238, an Accumulator data structure 240 and a 
5 ControlPointData data structure 242. The StaticPointData data structure 236 may 

contain static data for a particular device/point and may contain a Name variable which 
stores the name of the Point, a PtID variable containing a unique identification for the 
point, a SystemID variable as described above indicating the system to which the point 
is associated, a Group variable indicating a group to which the point is associated, a 

10 Priority variable indicating a weighting value for the point, a SortCode variable and a 
EU variable containing a text string which identifies the engineering unit associated 
with the particular point. For each point/device, there may also be the 
DynamicPointData data structure 238 containing dynamic data for a particular 
device/point. The DynamicPointData data structure may contain a PtID variable as 

15 described above, a Value variable indicating a value of the point, a MinValue variable 
indicating the lowest value for the point over a time interval, a MaxValue variable 
indicating the highest value for the point over the time interval, an AvgValue variable 
indicating the average value for the point over the time interval, a Timestamp variable 
indicating the time and date when the data was entered into the system, a Status 

20 variable indicating the status of the point, a PtType variable indicating a type of the 
point, and an Archive variable indicating if the current data is archived data. Each 
point may also have the AccumulatorData data structure 240 containing data about an 
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accumulator point in the device. The Accumulator Data may contain the PtID variable, 
a Delta PtID variable containing a delta value identification for a point, ROCPtID 
variable containing an identification for the rate of change of the point, and a Delta 
Multiplier variable containing a multiplier for calculating delta pseudo-points. Each 
5 point also has the ControlPointData structure 242 associated with it which contains 
information about the control of the point including the PtID variable, a CmdTimeout 
variable indicating an amount of time before a control command is timed out, a 
CmdlnProgress variable indicating if a command is currently in progress, the 
TimeStamp variable, a two control parameters (Paraml And Param2). 

10 The server may also have an ObjectRegistry data structure 244 to register 

requests for data. It may include a MonikerName variable containing a file name for 
each registered client, a MachineName variable indicating the machine that the object 
is associated with, a hEnsRtdb variable counting a Rtdb handle for each object, an 
ObjectType variable to indicate the type of the object, and a RunningState variable 

15 indicating the current state of the object. The server may also have a 

RtdbServerRegistry data Structure 246 containing data about the machine hosting the 
Rtdb server including the MachineName variable indicating the name of the machine 
hosting the Rtdb server, the MachinelD variable indicating the logical address, such as 
TCP/IP, of the machine, and the hEnsRtdb variable indicating the Rtdb handle for the 

20 machine. Thus, using this data structure, the real-time retrieval and dissemination 
system may uniquely identify and address each server and points. 
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While the foregoing has been with reference to a particular embodiment of the 
invention, it will be appreciated by those skilled in the art that changes in this 
embodiment may be made without departing from the principles and spirit of the 
invention, the scope of which is defined by the appended claims. 
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Claims : 

1 1 . A system for managing the facilities and the energy consumption of an 

2 enterprise of an entity, the enterprise comprising one or more geographically dispersed 

3 facilities and buildings, each building and facility having one or more devices which 

4 operate and consume energy, the system comprising: 

5 means for gathering information about the energy consumption and the 

6 operation of each device; 

7 an energy and facility management apparatus for controlling the facilities, 

8 buildings and devices in the geographically dispersed enterprise based on the energy 

9 consumption and operating information for each device, the energy management 

10 apparatus comprising means for communicating the energy consumption and operating 

1 1 data in real-time between the devices, the facilities and buildings and the energy and 

12 facility management apparatus; and 

13 a user interface for requesting energy consumption and operation data about 

14 one or more devices, facilities or buildings and for viewing the energy consumption 

1 5 and operation data about a predetermined portion of the enterprise. 

1 2. The system of Claim 1 , wherein the gathering means further comprises 

2 a gateway device connected to one or more of the devices for gathering energy 

3 consumption and operation data about the device and for converting the energy 
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4 consumption and operation data from a device format to a standard format and wherein 

5 the energy and facility management apparatus further comprises a server for processing 

6 the standardized energy consumption and operation data about the devices from the 

7 gateway to generate energy consumption management and facility management data, a 

8 plurality of user interfaces connected to the server, each user interface requesting data 

9 about one or more devices in the physical plant, and a concentrator connected to one or 

10 more of the user interfaces for interfacing between the user interfaces and the server, 

1 1 the concentrator comprising means for registering requests for data from a particular 

12 device by a particular client application, means for combining requests for data from 

13 the same device into a single data request from the server in order to reduce the amount 

14 of data requests to the server. 

1 3. The system of Claim 1 further comprising means for generating a 

2 representation of a particular selected facility in the enterprise based on the real-time 

3 energy consumption and operation data so that a user visually navigates through each 

4 facility. 

1 4. The system of Claim 3, wherein the generating means comprises a two- 

2 dimensional navigator. 
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1 5. The system of Claim 3, wherein the generating means comprises a 

2 three-dimensional navigator. 

1 6. The system of Claim 1 further comprising means for generating facility 

2 management data based on the energy consumption and operation data. 



1 7. The system of Claim 6 further comprising means for managing alarm 

2 signals generated by the facility manager and the energy manager in order to alert the 

3 user of the apparatus to alarm conditions in the geographically dispersed enterprise. 



1 8. A method for managing the facilities and the energy consumption of an 

2 enterprise of an entity, the enterprise comprising one or more geographically dispersed 

3 facilities and buildings, each building and facility having one or more devices which 

4 operate and consume energy, the method comprising: 

5 gathering information about the energy consumption and the operation of each 

6 device; 

7 controlling the facilities, buildings and devices in the geographically dispersed 

8 enterprise based on the energy consumption and operating information for each device 

9 using an energy and facility management apparatus comprising communicating the 
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10 energy consumption and operating data in real-time between the devices, the facilities 

1 1 and buildings and the energy and facility management apparatus; 

12 requesting energy consumption and operation data about one or more devices, 

1 3 facilities or buildings using a user interface; and 

14 viewing the energy consumption and operation data about a predetermined 

1 5 portion of the enterprise. 

1 9. The method of Claim 8, wherein the gathering further comprises 

2 gathering energy consumption and operation data about the device using a gateway 

3 device connected to one or more of the devices and converting the energy consumption 

4 and operation data from a device format to a standard format, and wherein the 

5 controlling further comprises processing the standardized energy consumption and 

6 operation data about the devices from the gateway using a server to generate energy 

7 consumption management and facility management data, requesting data about one or 

8 more devices in the physical plant by a user interface, and interfacing between the user 

9 interfaces and the server using a concentrator connected to one or more of the user 

10 interfaces comprising registering requests for data from a particular device by a 

1 1 particular client application and combining requests for data from the same device into 

12 a single data request from the server in order to reduce the amount of data requests to 

13 the server. 
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1 10. The method of Claim 8 further comprising generating a representation 

2 of a particular selected facility in the enterprise based on the real-time energy 

3 consumption and operation data so that a user visually navigates through each facility. 

1 11. The method of Claim 1 0, wherein the generating comprises using a two- 

2 dimensional navigator. 

1 12. The method of Claim 10, wherein the generating comprises using a 

2 three-dimensional navigator. 

1 13. The method of Claim 8 further comprising generating facility 

2 management data based on the energy consumption and operation data. 

1 14. The method of Claim 1 3 further comprising managing alarm signals 

2 generated by the facility manager and the energy manager in order to alert the user of 

3 the apparatus to alarm conditions in the geographically dispersed enterprise. 

1 1 5 . A system for communicating data in real-time between an energy and 

2 facility management system and one or more devices of an enterprise which consume 

3 energy, the system comprising: 
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4 a device interface connected to the one or more of the devices for gathering 

5 real-time energy consumption data and operational data about the one or more devices 

6 . connected to the device interface; 

7 a server connected to the device interface for storing the energy consumption 

8 and operation data for each device in the enterprise into a database, the energy 

9 consumption and operation data for each device being identified by a unique device 

10 address; 

1 1 a plurality of client applications, each client application requesting to receive 

12 energy consumption and operational data about one or more devices in the enterprise 

13 from the server; and 

14 a concentrator connected between the server and the one or more client 

15 applications, the concentrator comprising means for analyzing the requests for data 

16 from the client applications, means for combining requests for energy consumption and 

17 operation data about a particular device into a single combined request, means for 

18 communicating the single combined request to the server, and means for routing the 

19 energy consumption and operating data about the particular device received from the 

20 server to each client application which requests the energy consumption and operation 

2 1 data about that particular device. 
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16. The system of Claim 15 further comprising means for generating a 
representation of a particular selected facility in the enterprise based on the real-time 
energy consumption and operation data so that a user visually navigates through each 
facility. 

17. The system of Claim 16, wherein the generating means comprises a 
two-dimensional navigator. 

18. The system of Claim 1 6, wherein the generating means comprises a 
three-dimensional navigator. 

19. The system of Claim 15 further comprising means for generating 
facility management data based on the energy consumption and operation data. 

20. The system of Claim 19 further comprising means for managing alarm 
signals generated by the facility manager and the energy manager in order to alert the 
user of the apparatus to alarm conditions in the geographically dispersed enterprise. 
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1 21 . A system for communicating data in real-time between an energy and 

2 facility management system and one or more devices of an enterprise which consume 

3 energy, the system comprising: 

4 a device interface connected to the one or more of the devices comprising 

5 means for gathering real-time energy consumption data and operational data about the 

6 one or more devices connected to the device interface and means for storing the real- 

7 time energy consumption data and operational data into a database object; 

8 a server connected to the device interface for storing the energy consumption 

9 and operation data object for each device in the enterprise into a database, the energy 

10 consumption and operation data for each device being identified by a unique device 

11 object address; 

12 a plurality of client applications, each client application requesting to receive 

13 energy consumption and operational data about one or more devices in the enterprise 

14 from the server, each client application having a unique client address; and 

15 a concentrator connected between the server and the one or more client 

16 applications, the concentrator comprising means for analyzing the requests for data 

17 from the client applications, means for combining requests for energy consumption and 

1 8 operation data about a particular device into a single combined request, means for 

19 communicating the single combined request to the server, and means for routing the 

20 energy consumption and operating data about the particular device received from the 
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server based on the unique client addresses to each client application which requests 
the energy consumption and operation data about that particular device. 
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ENERGY MANAGEMENT SYSTEM AND METHOD 

Background of the Invention 

This invention relates generally to a system and method for managing the use 
of energy and in particular to a system and method for automatically managing the use 
of energy for a commercial user. 

The problem of energy management and energy cost management has always 
been an issue for many commercial users who operate large physical plants (i.e., 
facilities and/or factories) because of the large amount of energy which is consumed by 
the facilities or factories. It is desirable to manage and analyze the energy 
consumption of the physical plant in order to reduce the total energy costs of the 
physical plant. The energy management process may involve many steps such as, for 
example, purchasing energy from another less expensive source or adjusting the energy 
usage of the facility to off-peak times when energy rates are lower. A conventional 
system for energy management may be a computer system housed in the basement of a 
facility or factory, that permits a person to view the energy usage of various equipment 
within that particular facility and makes changes to the energy usage based on 
information received at the computer system. 

The problem of energy management is especially complex for large entities, 
such as corporations, universities, municipalities, etc., which may have a physical plant 
with many different facilities or factories located at various different locations. With a 
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conventional energy management approach, each facility owned by the large entity 
may independently manage its own energy. Thus, for a large entity, there must be a 
conventional energy management system associated with each facility or factory, 
which greatly increases the overall cost of conventional energy management. In 
5 addition, each energy management system may use a slightly different data structure 
for the data being generated so that these multiple energy management systems cannot 
be easily integrated into a single energy management system for the entire physical 
plant. 

In most conventional systems, the task of energy management is separated from 
10 the task of facilities management. Thus, each facility generally has both an energy 
management system and a facilities management system. To reduce the costs of the 
management of the facility, it is desirable to integrate these two systems into a single 
system. 

Therefore, it is desirable to provide a single integrated energy and facilities 
1 5 management system which connects a physical plant with multiple, possibly 

geographically dispersed, facilities or factories together so that the task of energy and 
facilities management may be accomplished at a single central location. The single 
control location may be remote from all of the facilities. It is also desirable to provide 
an energy and facilities management system which provides the user of the system 
20 with a simulation of the facilities being managed so that the user may view the 

physical plant without actually being at the site. Thus, it is desirable to provide an 
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energy management system and method which provides the above advantages and 
avoids the problems with the conventional systems, and it is to this end that the present 
invention is directed. 

Summary of the Invention 

5 In accordance with the invention, an energy and facilities management system 

is provided for energy users with large physical plants which provides these energy 
users with a comprehensive understanding of the energy consumption of their physical 
plant and with the ability to manage it in a way that makes sense for their business. 
The system accomplishes this goal by using, for example, three dimensional facilities 

10 navigation tools, powerful energy consumption analysis processes, TCP/IP 

communication capabilities and a World Wide Web (WWW)-based interface. The 
system therefore present large amounts of real-time energy data to users in a clear, 
concise and useful format. The system permits the user to alter energy consumption 
patterns and/or procure power more intelligently in order to save money. To 

15 accomplish the real-time movement of the large amounts of energy data, the system 
may include a robust, scaleable real-time data server component and a scaleable 
database which allows for flexibility and ease of integration between products and 
modules. The real-time server permits the system to provide a web-based interface 
which allows multiple users from a variety of locations to access important energy 

20 information at a much lower cost versus existing energy management systems. 
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The system, in accordance with the invention, may be divided into one or more 
sub-systems which manage different portions of the physical plant of the entity. For 
example, there may be an energy manager, a facility navigator, a facility manager and 
an alarm manager in a preferred embodiment of the invention. Each of these sub- 
systems performs operations which permit an employee of the entity to control and 
manage its facilities including its energy consumption. For example, the energy 
manager may track and/or analyze energy usage data, the navigator may permit the 
user to visualize each facility through a simulation, the facility manager may analyze 
control problems, and the alarm manager may notify the user of alarms and response to 
alarms as appropriate. Each of these sub-systems work together to provide an 
integrated energy and facility management system. 

In accordance with another aspect of the invention, a system and method for 
moving data between the various sub-systems within the energy management system is 
disclosed. The data moving method concatenates data at one or more sources such that 
the total amount of data being communicated between the sub-systems is reduced. 

Thus, in accordance with one aspect of the invention, a system for managing 
the facilities and the energy consumption of a physical plant is provided in which the 
physical plant has one or more facilities and buildings in which each building and 
facility has one or more devices which operate and consume energy. To accomplish 
the management of the physical plant, the system may gather information about the 
energy consumption and operation of each device in the physical plant and control the 
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facilities, buildings and devices in the physical plant, based on the energy consumption 
and operating information for each device, by communicating the energy consumption 
and operating data in real-time between the devices and the energy and facility 
management apparatus. The system may also include a user interface for requesting 
energy consumption and operation data about one or more devices and for viewing the 
energy consumption and operation data about the physical plant. A method for energy 
and facility management is also provided. 

In accordance with another aspect of the invention, an apparatus for managing 
the facilities and energy consumption of a physical plant including one or more pieces 
of equipment and one or more facilities is provided in which data is received from each 
facility corresponding to building control signals, energy usage signals and weather 
data and external data is received corresponding to energy rates and weather forecasts. 
The apparatus may generate energy management data for the facilities and equipment 
in the physical plant based on the facility data and the external data. It may also 
generate a representation of each facility in the physical plant so that a user navigates 
through each facility. The apparatus may also generate facility management data to 
help a user of the apparatus control the facilities of the physical plant. 

In accordance with another aspect of the invention, a system for 
communicating data in real-time between an energy and facility management system 
and the devices of a physical plant is provided in which a plurality of devices in the 
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physical plant operate and consume energy. The system may include a device interface 
connected to one or more of the devices for gathering energy consumption and 
operation data about the one or more devices connected to the device interface and a 
server connected to the device interface for storing the energy consumption and 
5 operation data for each device in the physical plant. The system may further include a 
plurality of client applications which request to receive energy consumption and 
operation data about one or more devices in the physical plant from the server, and a 
concentrator connected to one or more of the client applications. The concentrator may 
analyze the requests for data from the client applications, combine requests for energy 
10 consumption and operation data about a particular device into a single combined 

request, communicate the single combined request to the server, and route the energy 
consumption and operating data about the particular device received from the server to 
each client application which requests the energy consumption and operation data 
about that particular device. 

15 Brief Description of the Drawings 

Figure 1 is a diagram illustrating a geographically diverse enterprise having one 
more facilities and an integrated energy and facilities management system; 

Figure 2 is a block diagram illustrating an energy and facility management 
system in accordance with the invention; 
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Figure 3 is a diagram illustrating the data flow through the energy and facility 
management system shown in Figure 2; 

Figure 4 is a diagram illustrating more details of the real-time data topology of 
the energy and facility management system of Figure 2; 

5 Figure 5 is a flowchart illustrating a method for updating data in real-time in 

accordance with the invention; 

Figure 6 is a flowchart illustrating a method for registering a client and with a 
concentrator device in accordance with the invention; 

Figure 7 is a flowchart illustrating the operation of the client and concentrator 
10 device in accordance with the invention; and 

Figure 8 is a diagram illustrating the real-time data structures for the server in 
accordance with the invention. 

Detailed Description of a Preferred Embodiment 

The invention is particularly applicable to an energy and facility management 
15 system for an energy user having a widely dispersed enterprise with widely dispersed 
energy consuming factories or facilities. The energy and facility management system 
may use a public global communications network known as the Internet/Intranet to 
communicate data between the elements of the system. It is in this context that the 
invention will be described. It will be appreciated, however, that the system and 
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method in accordance with the invention has greater utility, such as to other smaller, 
less complex physical plants and may use a variety of communications systems, 
including a private network, to communicate the data. 

Figure 1 is a block diagram illustrating a physical plant 10 of a large entity 
which may be controlled and managed by a central energy and facilities management 
system 12 in accordance with the invention. As shown, the physical plant of the entity 
may include one or more facilities 14 (Facility #1, Facility #2, Facility #3 and Facility 
#N) each of which consumes power and has facilities management requirements. In 
this example, these facilities may be located in widely disparate geographic locations, 
such as Palo Alto, California, Los Angeles, California, New York and Texas. It should 
be noted that the invention, however, is not limited to any particular number of 
facilities or the locations of those facilities since the system may also be used for an 
entity with just a few facilities in the same geographic location. As described above, it 
is desirable to be able to control and manage the energy consumption and other 
facilities problems from a single centralized location. 

To provide a centralized energy and facilities management system, the system 
12 may be interconnected to the facilities 14 by any conventional communications 
systems 16. In a preferred embodiment, the system 12 and the facilities 14 may be 
interconnected by the Internet/Intranet. The communications system permit data to be 
communicated between the facilities 14 and the energy and facilities management 
system 12 in real-time. To provide an interface between the energy and facilities 
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management system 12 and each facility 14, each facility may include an energy 
management device (EM) for communicating data between the energy and facilities 
management system 12 and the facility 14 as described below in more detail. In 
particular, the combination of the system 12 and the EM devices permit real-time data 
5 to be communicated between the system 12 and the facilities 14. In accordance with 
the invention, a user at the energy and facility management system 12 may control and 
manage each of the facilities without necessarily being on-site at any of the facilities. 
The energy and facilities management system 12 may permit, for example, the energy 
usage of each facility to be monitored and an alarm sounded if a predetermined 

10 condition occurs. Because the energy and facility management system 12 is connected 
to the facilities 14 by a communications system 16, the energy and facility 
management system 12 may be located at any geographic location while providing 
complete control and management of all of the facilities in the physical plant 10. In 
addition to the facilities 14, one or more user terminals 17 may also be connected to the 

15 system 12 by the communications system 16, which may preferably be the 

Internet/Intranet. These terminals 17 may be located at any location where access to 
the communications system 16 is available. For example, a manager may access real- 
time energy data from a facility in Singapore while in New York. In addition, there 
may be multiple people at various different locations accessing different or the same 

20 energy data at the same time due to the real-time data retrieval and dissemination 

system as described below in more detail. Thus, anyone in the entity may access any 
energy data about the physical plant at any time. The actual data displayed to each 
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user may be customized based on the user's needs so that each user may receive 
different data or the same data presented in a different way. For example, a CFO may 
receive a different set of data than an energy manager. Now, the energy and facilities 
management system 12 will be described in more detail. 

5 Figure 2 is a block diagram of the energy and facilities management system 12 

in accordance with the invention which provides energy and facilities management 
capabilities for a physical plant. The system may include one or more internal data 
sources 22, one or more external data sources 24 and an energy and facility 
management apparatus 26. The internal data sources 22 may be devices internal to the 

10 facility which generate data about the facility used for energy and/or facility 

management. For example, the internal data sources may include a building control 
gateway 28 which provides one or two-way data communications between the existing 
controls of the facility and the apparatus 26, a meter gateway 30 which provides data to 
the apparatus 26 about the energy usage of the facility, and a weather gateway 32 

15 which provides various weather data, such as humidity or temperature, to the apparatus 
26. The external data sources may be data sources which are outside of the particular 
facility, but which also provide data which is useful for energy and facility 
management. For example, the external data sources may include a market energy 
rates source 34 which contains data about the energy costs for various energy providers 

20 and a weather data source 36 for providing future weather forecasts for each facility. 
Using the various data from the internal and external data sources 22, 24, the energy 
and facility management apparatus 26 may, for example, track energy usage or change 
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energy usage patterns based on the forecast weather or based on a less expensive 
energy provider. The various energy management processes will be described below 
in more detail. 

The apparatus 26 may be a computer system which executes a plurality of 
5 different software packages which implement the functions of the system which are 
described below. As shown, the apparatus 26 may include an energy manager 40, a 
facility navigator 42, a facility manager 44 and an alarm manager 46. Thus, the 
apparatus may be divided up into four components and a customer may select features 
from some or all of these components to create a product bundle that most closely fits 
10 their needs. The invention, however, is not limited to an apparatus which includes all 
of these components and thus the invention may include only one or more of the 
components. Each of these components may be implemented as a piece of software 
being executed by a server computer, for example. Each of these components will now 
be described in more detail. 

1 5 The energy manager 40 gathers energy usage data and permits users of the 

system to view and analyze energy usage over any combination of facilities or time 
periods. The energy manager may permit the user to diagnose energy usage problems 
and develop strategies to reduce energy costs by optimizing responses to queries by the 
user based on the time of day, the current energy rate and environmental conditions. 

20 The energy manager may receive data from a variety of sources, such as utility meters 
in the facility. The energy manager may perform a variety of functions, such as 
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tracking energy usage, analyzing energy usage by analyzing historical energy usage 
data or analyzing energy load aggregation data, energy rate analyzing, energy usage 
forecasting based on various data such as forecast weather conditions, power 
procurement analyzing, such as generating a request for purchase (RFP), analyzing the 
5 energy usage of different sites and comparing the sites to each other and alarm 

signaling. In more detail, the usage tracking may include monitoring and generating 
trends for real-time energy usage of each facility in various energy units, such as 
kilowatts (KW), kilowatt hours (KWH), or British thermal units (BTUs). The usage 
tracking may also include aggregating energy loads for the various facilities and 

10 retrieving and comparing historical energy usage with real-time energy usage. The 
energy usage analysis may include an energy load shape analysis, a peak energy 
demand determination, an identification to determine the largest energy consumers 
and/or the consumers who use the energy during the peak energy usage time, and a 
determination of energy load and energy power factors as is well known. The rate 

15 analysis may include determining energy costs based on existing rates on a per meter, 
per building, per site, per cost center or corporate wide basis, an energy load scenario 
builder in which different energy rates scenarios may be played out to determine the 
best rate for the entity compared to a base scenario, generating energy bills, and 
viewing real-time and historical energy demand levels on a per meter, per building, per 

20 site, per cost center or corporate wide basis. The usage forecasting may use weather 
data to forecast a future day, week, month or year's energy usage. An alarm signaling 
function may generate an alarm signal when certain conditions occur, such as energy 
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load peaks, power spikes, surges, sags and deviations from an acceptable signal quality 
and keep track of the total number of alarms. Now, the facility navigator 42 will be 
described in more detail. 

The facility navigator 42 may permit any user of the energy and facility 
5 management apparatus 26 who is connected to the apparatus by the communications 
system 16 (see Figure 1) to view real-time two-dimensional or three-dimensional 
representations of any facility in the physical plant, to configure a particular site, to 
analyze and locate energy or facility management problems at a site, or to generate a 
report. In particular, the facility navigator may permit a user to navigate and analyze 

10 problems at multiple sites using advanced 2-D and 3-D visualization tools. In more 
detail, the two-dimensional navigator may generate graphical representations of the 
details of the facilities, sites and the like to permit the user to navigate through all of 
the sites, through a site to a specific building on a site, or through a particular building 
on a site. The navigator may also generate visual representations of an event, such as 

15 an alarm or excessive power usage, so that the user may see these events when they are 
navigating through the site or building. As an example, the navigator may display a 
particular building as red indicating that the building is using too much power based on 
past history and the user of the navigator will see the red building and may investigate 
the problem. The navigator may also permit the user to look at individual systems in a 

20 building, such as HVAC system or equipment components, to analyze a problem. The 
three-dimensional navigator may perform similar functions as the two-dimensional 
navigator, but in three-dimensions. The site configuration functions permits the user of 
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the apparatus to customize , create or update a particular site to add various 
information. For example, the site configuration may permit the user to generate a site 
map for a newly opened facility which is going to be managed by the apparatus 26. 

The facility manager 44 may integrate existing building control systems to 
5 permit the user of the apparatus to have access to data from the existing building 
control systems as well as newly installed systems so that the apparatus 26 may be 
easily integrated with existing systems. The facility manager may perform data 
monitoring and collection processes which may include monitoring, trending and 
archiving data (i.e., temperatures, pressures, flows, levels, set points and states) about 

10 existing systems, such as HVAC systems, boilers, chillers, cooling towers, generators, 
compressors, motors and pumps and lighting. The facility manager may also monitor 
and trend (i.e., determine a trend and how the particular quantity will act in the future) 
environmental conditions, such as lighting, interior and exterior temperatures, relative 
humidity, solar radiation and the like. The facility manager may also monitor and 

1 5 display peak facility operating periods. The facility manager may also analyze 

equipment efficiencies under partial and full load, develop operating efficiency load 
profiles, track operating hours and benchmark load profiles against capacity ratings. 
The facility manager may also optimize the existing systems by, for example, 
balancing HVAC operating times to meet building use periods and environmental 

20 changes, and optimize existing equipment's usage. The facility manager may also 

control the existing systems and devices and initiate soft starts, hard starts and stops of 
the equipment, program control set-points and provide a manual override of the 
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systems and equipment. 

The alarm manager 46 handles any alarms generated at any point in the 
apparatus 26 or physical plant 10. For example, it may collect alarm information from 
the energy manager or the facility manager and then prioritize these alarms. The alarm 
5 manager may also notify the appropriate people, by various different methods, such as 
e-mail, fax or pager, who need to respond to a particular alarm. Now, the flow of data 
through the energy management system in accordance with the invention will be 
described with reference to Figure 3. 

Figure 3 is a diagram illustrating an example of a physical plant 50 of a 
10 commercial user which may include one or more buildings 52, 54, 56, 58 and 
additional equipment and devices (D) which may be controlled by the energy 
management system in accordance with the invention. The energy management 
system may include one or more computer systems 60, 62, 64 which may be server 
computers which interconnect the various buildings and equipment of the physical 
15 plant for purposes of controlling and managing the buildings and the equipment. In the 
example shown, the energy management system may include the central server 60 
which receives data and information from the other servers, the buildings and the 
equipment. The invention, however, is not limited to a energy management system 
with a central server. 

20 At each building, a user executing a client application on a personal computer, 

for example, may query one of the servers and receive data about some portions of the 
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entity's physical plant. In the example shown in Figure 3, each client application 
requesting data about the enterprise may be represented by a client object in an object 
oriented programming language. Therefore, in accordance with the invention, in order 
to provide information to a particular client application, the client object corresponding 
5 to the client application may be modified and then the client application may read the 
modified client object. For example, in building 54, a first client application/object 66 
and a second client application/object 68 may access information about the physical 
plant. In the embodiment shown, the client applications may be client software 
applications being executed on a computer system within the building which access 

10 data from the servers. In the preferred embodiment, the client applications/objects may 
be Internet/Intranet browser software applications which access the servers over the 
Internet/Intranet to communicate data and commands to the servers. For locations, 
buildings or sites in which more than one client application is being executed, the 
energy management system may include a data concentrator (C) which attempts to 

15 reduce the data traffic between the client application and the servers by combining 

requests from the client applications into a single request. For example, if both client 
applications are requesting the same updated data about a particular piece of 
equipment, the concentrator may generate a single request for the data and then 
communicate that updated data to each client application once the updated data is 

20 received by the concentrator. 

The equipment and devices (D) may be connected to the servers 60 - 64 by a 
gateway (G) which acts as an interface between the device D and the servers. In 
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particular, the gateway may be a software application which interprets the particular 
device or equipment's signals into standardized data which may then be stored by the 
servers. Therefore, each gateway G may be somewhat unique since it converts signals 
from a particular device D into a standard format. 

5 In operation, the devices D may generate data about the operation of the device 

or its energy usage and pass the data to the gateway which forwards it on to the server 
which stores the data. When a client application requests data about a device, the 
request is passed to the concentrator associated with the application which filters out 
any duplicate requests. Then, when a concentrator requests data about the device, the 
10 server may communicate the data to the concentrator which passes the data onto the 
appropriate client application. A similar process may occur to update data about a 
device. To accomplish the real-time retrieval and dissemination of data, a unique 
address is assigned to each device and client application in the real-time data retrieval 
and dissemination system as will now be described. 

15 Figure 4 illustrates more details of a real-time data retrieval and dissemination 

system 100 in accordance with the invention. In a preferred embodiment, the real-time 
data retrieval and dissemination system 1 00 may be implemented as a sophisticated 
software system containing a plurality of software applications which can perform 
various energy and facility management tasks. For example, the system 100 may 

20 remotely interface to various data acquisition and control systems over existing data 
networks (i.e., an internal computer network or the Internet/Intranet) thereby 
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eliminating the need for proprietary, expensive cabling to remotely locate a control 
system user-interface software application which permits a user to control and manage 
the entire physical plant of an organization from one location. In addition, because the 
system 100 interfaces to and consolidates the data from a variety of different systems 
5 having possible different data protocols into a central data server, a user of the system 
may utilize a common workstation to access and combine the functionality of different 
control systems from the same location using the same software. As with the 
equipment and physical plant which may be distributed over a large geographic area, 
the client software applications, which permit access to the data, may also be located 

10 anywhere within the span of the data network. This is especially advantageous since 
the number and type of client applications requesting for real-time information will 
grow significantly in the future, as this information becomes integral in optimizing the 
asset utilization of the enterprise. This permits the system to be scaleable and 
accommodate future expansion of the physical plant. It also permits the person 

15 controlling the physical plant to access data about the physical plant from any location. 
It also permits other people in the organization, such as the chief financial officer, to 
access data about the physical plant from his desktop computer which has a browser. 
In the example shown, the system 100 may include a central server computer 102, one 
or more client personal computers 104, 106, 108, one or more gateways 110, 112, 114, 

20 116 which connect one or more devices 118, 120, 122, 124, 126 to the server 102. 
Each of these will now be described in more detail. 
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The data gateways 110, 112, 114, 116 may be stand-alone software application 
modules that interface with the devices to perform data acquisition and to control the 
devices. As shown, multiple control systems or data collection devices of different 
types may be supported by a single data gateway. The communication medium 
5 between the gateway and the data collection device may vary. The data gateways may 
also be connected to a second data network to permit the gateway to communicate data 
with the server 102 to perform various functions, such as exchanging collected data or 
forwarding control commands from the energy management system to individual 
devices for execution. Each gateway may also include a configuration system 127 for 
10 configuring the gateway to a particular device. Now, the server 102 will be described 
in more detail. 

The server 102 is the controller for the real-time data retrieval and 
dissemination system. The server may be implemented as an individual software 
process executing on a single computer or as several software processes being executed 

15 on a network of multiple computer systems. In either case, the configuration of the 

server is transparent to the client software application being executed by the client PCs. 
The distributed server architecture with multiple servers executing various pieces of 
software may be especially well suited for scaling up the energy management system 
to handle very large applications of real-time data without affecting any development 

20 within the client application. In accordance with the invention, the server may execute 
software applications which implement the various sub-systems described above with 
reference to Figure 2. The server 102 may include a real-time database (Rtdb) 128 and 
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a configuration database 129 which communicate with each other. The Rtdb may 
receive data from the gateways, issue commands to the devices, and disseminate data 
to the client PCs 104-108. The configuration database 129 may receive configuration 
data from a gateway for a particular device and forward updated configuration data to a 
device and gateway. More detail about the operation of the server will be described 
below. 

Each client PC 104, 106 or 108 may include one or more client objects 130, 
132, 134 which are connected to a concentrator 136. As described above, the client 
objects, which may be software applications being executed by the client PC, such as a 
Internet/Intranet browser, may generate requests for data from the server 102 which the 
concentrator 136 may combine together if possible. The concentrator 136 thus may act 
as a data traffic controller to prevent the client objects from overloading the server 102 
with duplicate requests. The concentrator, therefore, reduces the data traffic flow 
between the server 102 and each PC. The client application may consist of one or 
more stand-alone software application programs or modules that can communicate 
independently to the server 102 to receive real-time data updates of data element status 
changes which are displayed visually for the client in a variety of ways, such as using a 
web browser. Thus, data is automatically updated for each client application as will 
be described in more detail below. Now, the flow of changed data through the real- 
time retrieval and dissemination system 100 will be described to better understand the 
operation of the system. 
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When a data change occurs on a device 1 18 - 126, a data gateway 1 10 - 116 
attached to the device may detect or be signaled of the data change depending on the 
capabilities of the device. Once the gateway receives the changed data, it may 
preprocess the data to standardize it for the energy management system and 
5 communicate it onto the Rtdb server 102. Upon arrival of the changed data at the Rtdb 
server , the Rtdb server checks an update list to determine which concentrators 136 are 
currently registered to receive data updates for this device. The current list of 
concentrators which receive the updated data for a particular device changes in real- 
time based on what data each concentrator is currently requesting or what data is being 
10 currently displayed by each client PC. 

Once the list of registered concentrators is determined, the Rtdb server may 
send the updated data to each concentrator 136. When a data update is received by a 
concentrator, the concentrator may in turn check a local list to see which client 
applications/objects 130- 134 attached to the particular concentrator are registered to 

15 receive the particular data updates. Next, the client concentrator may send the data 
update to each individual client application which updates its display based on the 
updated data. The client concentrator 136 therefore optimizes the efficiency of the data 
communication network by concentrating identical point data update registrations from 
multiple client applications/objects into a single request for data from the Rtdb server. 

20 Therefore, data requests by multiple client applications/objects may be serviced by a 
single data point update message from the Rtdb server which may be referred to as a 
point concentration process. 
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The point concentration process extends itself beyond the client objects to the 
Rtdb server 1 02 so that the server may act as a hub for all points (devices) that it 
services from its attached gateways, but in addition act as the hub for points from other 
Gateways attached to other Rtdb servers. Therefore, any client application/object that 
5 needs real-time updated information from any Gateway will receive that data from a 
local Rtdb server, who in turn is responsible for obtaining that information from other 
Rtdb servers, if necessary. To accomplish this, each server 102 may be viewed as just 
another concentrator to each "remote" Rtdb server. In other words, for data requested 
from another server, each server may concentrate multiple data requests for 
10 concentrators and client applications attached to it into a few data requests to reduce 

data traffic. Thus, the Rtdb server exhibits the same network optimization strategies as 
the client concentrator objects by concentrating identical point update registrations 
from multiple concentrators into a single registration to the remote Rtdb server. 

Throughout the system 100, registrations (requests) for real-time point (device) 
15 updates are initiated by client applications/objects by specifying a unique machine 

identifier and a unique point identifier combination for each device/point of interest to 
its associated concentrator. Thus, each server (machine identification) and 
device/point (point identification) has a unique address so that data may be efficiently 
routed through the communications network. For example, a client application 
20 attached to server A may request data from a device B by issuing a command 

indicating that A requests data about B so that the command contains the necessary 
addresses used by the concentrator and other server to route the data about device B to 
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the client application attached to server A. The concentrator then registers these 
points, if not already registered, with a local Rtdb server. Based on the machine 
identifier associated with each registered point, the Rtdb server can then pass a 
registration onto another Rtdb server if necessary, again, only if this point has not 
5 already been registered with that Rtdb server. This system of concentrating and 
forwarding point registrations lends itself to very simplistic administration because 
each Rtdb server requires no advance knowledge of other Rtdb servers anywhere else 
in the world as the machine identifier contains all of the information required to locate 
a Rtdb server. For example, the machine identifier may be composed of a unique 
10 TCP/IP address, a unique Uniform Resource Locator (URL), or a unique Domain 
Name Service (DNS) name which permits each Rtdb server to be individually 
identified. This process also naturally lends itself to scale up to handle very large real- 
time data applications. 

In summary, to accomplish the real-time data retrieval and dissemination in 
15 accordance with the invention, each client application/object is given a unique address, 
such as that contained in a MachinelD variable and each point or device is given a 
unique address, such as that contained in a PtID variable. Thus, for any data request or 
any update of existing data, there is an associated PtID or MachinelD variable which 
permits the system to rapidly communicate the data only to the clients which need the 
20 information. Now, the operation of the server during a point data update will be 
described. 
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Figure 5 is a flowchart illustrating a method 150 for point data updating at the 
server in accordance with the invention. In step 152, a gateway attached to the 
device/point with updated data call a Rtdb.UpdatePoint software subroutine which 
stores values for various variables, such as a machine identification (MachinelD), a 
5 point identification (PtID), a value of the changed data (Value), a date and time of the 
data change (DATETIME) and a status of the point/device at the time of the change 
(status) and passes the values in the variables onto the server. The server, in step 154, 
then fetches the updated data using the values contained within the subroutine 
variables from the gateway and stores the values in temporary storage while an 
10 authentication process occurs. 

In the next series of steps, the server authenticates the data update prior to 
distributing the data update values to other servers and/or clients. Thus, in step 156, 
the server determines whether the gateway is marked as running (i.e., Whether the 
server is aware of any problem with the gateway) when the update data subroutine is 

15 invoked. If the server detects that the gateway is not running, the data update process 
ends and no data update is completed. If the gateway is running, then in step 158, the 
server checks its data records to determine if the point with a data update is actually 
known to the server since the server maintains a list of the points which are connected 
to it. If the point is unknown, the method ends and no data update is completed. If the 

20 point is known to the server, then the server determines if the updated data from the 
known point has the proper data type in step 160. If the data type is not correct, the 
method ends and no data update is completed. Thus, in steps 156 - 160, the server may 
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authenticate a point data update prior to distributing the data update in order to reduce 
incorrect data within the system. Thus, each server attached to each point may act as a 
filter for updated data from that point. 

Next, in step 162, the server updates various variables in a real-time 
5 (Rtdb)database in the server to reflect the updated data values. In particular, the server 
may update the values of a Rtdb. Value variable containing the new updated value of 
the point data, a Rtdb.Timestamp variable containing the time and date information 
about when the data as updated, and a Rtdb. Status variable containing information 
about the status of the point when the data update occurred. In the next series of steps, 
1 0 the server may determine the appropriate one or more other servers or concentrators to 
which the updated point data may be communicated. This process may be referred to 
as a Point Hot Link Manager shown diagramatically as step 1 64 in the flowchart. 

The Point Hot Link Manager process starts at step 166 in which the server 
determines, based on a list maintained in the server, which clients may be 

15 linked/registered to the particular point which has updated data. If there are no known 
clients which are registered to receive the updated data, the method ends and the 
updated data is being retained in the server until a client requests the data. In step 168, 
the server may determine, from its internal list, whether the particular client is another 
Rtdb server, a concentrator or something else based on the Machine ID variable. If the 

20 client is not another Rtdb server or a concentrator, the method ends. If the client is 
another server or a concentrator, then in step 170, the server may retrieve a pointer to 

25 



WO 00/17984 



PCT/US99/21787 



the particular client's interface from an internal file moniker. Next, in step 172, the 
server may call an Object.UpdatePoint subroutine which updates various variables, 
which are described above, in a data structure which is then communicated to the 
client. In this example shown, a MachinelD variable, a PtID variable, a Rtdb. Value 
5 variable, a Rtdb.Timestamp variable and a Rtdb. Status variable are updated to reflect 
the change in the point data. The calling of the subroutine thus updates the values for 
the particular client as identified by the MachinelD variable value so that client 
automatically receives the updated data anytime an update occurs. 

Next, in step 174, the server determines if there are any more clients who are 
10 registered to receive the updated data. If there are additional clients who are registered 
to receive the updated data, the method loops back to step 168 and repeats steps 168 - 
172 to update the data for the next client. Once all of the clients who are registered to 
receive data updates for the particular point are accounted for, the method ends. In this 
manner, for each point data update, the server may perform some authentication of the 
1 5 updated data and then proceed to distribute the updated data only to those clients which 
are registered with the server using the unique addresses as described above. In this 
manner, the method reduces the amount of data traffic over the communications 
network. Now, a method by which each client application/object may register itself to 
receive data updates from a particular point will be described. 

20 Figure 6 is a flowchart illustrating a method 1 80 by which a particular client 

application may become registered to receive data updates from a particular 
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point/device. In step 1 82, the client application may identify the points from which the 
client application wants to receive data. In particular, the client application may build 
an IPointsCollection data structure containing a collection of the IPointData objects 
that identify the one or more data points about which the client is interested in 
5 receiving data. The data structure may contain a plurality of data structure of the form 
"MachineName::point name". For example, the user of client application A may be 
currently viewing the data regarding device/point B and therefore, the client 
application will enter a data structure of the form "A::B" indicating that the particular 
client application wants to receive data updates about device B. This data structure 
10 may be maintained until the user is no longer viewing the data from device B. Next, in 
step 1 84, the client application may call a subroutine to register the request for the data 
from the particular point with the concentrator connected to the client application. In 
the example shown, the subroutine may be called with the command 
Concentrator.RegisterPoints(IPointsDataCollection * *pPoints). 

15 In the next series of steps, the concentrator may register the point data requests 

and determine if a request has already been made for the same point data by either the 
same client application or another client application connected to the same 
concentrator. This permits the concentrator to reduce the total data traffic by 
concentrating requests for data from a particular point by one or more clients into a 

20 single data request to the server. The concentrator then distributes the point data to the 
appropriate client applications. For each point name in the points collection, the 
concentrator may attempt to identify the point in step 186. In step 188, the 
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concentrator determines if the point has already been identified (i.e., has the 
concentrator already previously received data or data requests about the point). If the 
point has not been previously identified, then the concentrator may perform a series of 
steps to request the data for the particular point from an attached server. Thus, in steps 
5 190, 192 and 194, the concentrator may generate a RtdbRegistrar.GetStaticPointData 
command to get any static data about the point, a RtdbRegistrar.GetDynamicPointData 
command to obtain any dynamic data about the point, and a RtdbRegistrar. Subscribe 
command indicating that the concentrator is registered with the server for the particular 
point so that the concentrator should automatically receive any updates to the point 
10 data as described above. 

If the point has already been previously identified (i.e., the concentrator already 
has the data about the point and any updates), then in step 196, the concentrator may 
fill in various variables in a data structure with the values for the data for the particular 
point. In the example shown, the MachinelD, PtID, Value, Timestamp, 

15 ControlCmdTimeout and Status variables may be filled in to provide the data to the 
particular client. Next, in step 198, the concentrator determines if there are any other 
point names to identify and loops back to step 188 if there are additional point names 
to identify. If there are no other point names to identify, the method is completed. In 
summary, this method permits a client application to register its need for data about a 

20 particular point and permits the concentrator to avoid unnecessary data traffic by 
combining requests about data from the same point by different clients. Now, a 
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method by which the concentrator receives updated data from a server in accordance 
with the invention will be described. 

Figure 7 is a flowchart illustrating a method 210 by which a concentrator 
receives updated data for a point from a server in accordance with the invention. In 
5 step 212, the server calls a subroutine to populate a data structure with the updated 
data. In the example shown, the subroutine called is "Concentrator.UpdatePoint" and 
it updates values in a MachinelD variable, a PtID variable, a Value variable, a 
Timestamp variable and a Status variable. Then, in step 214, for each PointsCollection 
containing the correct MachinelD value and PtID value, the server may update the 

10 values of the point data by updating (step 216), for example, a PointData. Value, a 

PointData.Timestamp and a PointData. Status variable. Next, to provide the update to 
the various clients registered to receive it, the server may call a subroutine, such as 
PointsDataCollection.OnUpdatePoint, in step 218, to update the MachinelD, PtID, 
Value, Timestamp and Status values in the appropriate variables. Next, in step 220, 

15 the concentrator determines if there are any other PointsCollections which contain the 
same MachinelD and PtID values as the current updated data. If there are no other 
PointsCollections with the same MachinelD and PtID values, the method is completed. 
If there are additional PointsCollections data structure containing the same MachinelD 
and PtID values, the method loops back to step 216 to handle the other 

20 PointsCollections. In this manner, when new updated data for a particular point is 

received by the concentrator, the concentrator then goes through a process to identify 
clients attached to it which have registered to receive the updated data and passes the 
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updated data onto only the clients which are registered to receive the updated data. 
Now, an example of the data structures which are utilized by the server in accordance 
with the invention will be described. 

Figure 8 is a diagram illustrating examples of the various data structures 
utilized by the server in accordance with the invention. It should be noted that this is 
only an example of the data structures and the invention is not limited to any particular 
data structure. As shown, each site of a physical plant may have a site data structure 
230 associated with it which may contain a description variable containing a 
description of the particular site and a SitelD variable containing a unique address for 
the site. Each location (i.e., building or other location) within a site may have a 
location data structure 232 which may include a Tag variable containing a unique short 
name for the location, a LocationID variable containing a unique address for each 
location, the SitelD variable as described above identifying the site on which the 
location exists, a description variable containing a description of the locations, such as 
building 42, a NumFloors variable indicating the number of floors in the building, a 
SqFeet variable indicating the square footage of the location, a TextureType variable 
indicating the texture that may be used to render the building during the facility 
navigation, a DemandThreshold variable indicating when an alarm is generated for a 
particular reading, and a Group variable indicating a group to which the location 
belongs. Each data acquisition may have a system data structure 234 associated with it 
which contains a Description variable containing a description of the particular data 
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acquisition, a SystemID variable containing a unique address for each system, and a 
LocationID variable, as described above identifying the location of the system. 

For each point/device, there may be a StaticPointData data structure 236, a 
DynamicPointData data structure 238, an Accumulator data structure 240 and a 
5 ControlPointData data structure 242. The StaticPointData data structure 236 may 

contain static data for a particular device/point and may contain a Name variable which 
stores the name of the Point, a PtID variable containing a unique identification for the 
point, a SystemID variable as described above indicating the system to which the point 
is associated, a Group variable indicating a group to which the point is associated, a 

10 Priority variable indicating a weighting value for the point, a SortCode variable and a 
EU variable containing a text string which identifies the engineering unit associated 
with the particular point. For each point/device, there may also be the 
DynamicPointData data structure 238 containing dynamic data for a particular 
device/point. The DynamicPointData data structure may contain a PtID variable as 

15 described above, a Value variable indicating a value of the point, a MinValue variable 
indicating the lowest value for the point over a time interval, a Max Value variable 
indicating the highest value for the point over the time interval, an Avg Value variable 
indicating the average value for the point over the time interval, a Timestamp variable 
indicating the time and date when the data was entered into the system, a Status 

20 variable indicating the status of the point, a PtType variable indicating a type of the 
point, and an Archive variable indicating if the current data is archived data. Each 
point may also have the AccumulatorData data structure 240 containing data about an 
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accumulator point in the device. The Accumulator Data may contain the PtID variable, 
a Delta PtID variable containing a delta value identification for a point, ROCPtID 
variable containing an identification for the rate of change of the point, and a Delta 
Multiplier variable containing a multiplier for calculating delta pseudo-points. Each 
5 point also has the ControlPointData structure 242 associated with it which contains 
information about the control of the point including the PtID variable, a CmdTimeout 
variable indicating an amount of time before a control command is timed out, a 
CmdlnProgress variable indicating if a command is currently in progress, the 
TimeStamp variable, a two control parameters (Paraml And Param2). 

10 The server may also have an ObjectRegistry data structure 244 to register 

requests for data. It may include a MonikerName variable containing a file name for 
each registered client, a MachineName variable indicating the machine that the object 
is associated with, a hEnsRtdb variable counting a Rtdb handle for each object, an 
ObjectType variable to indicate the type of the object, and a RunningState variable 

15 indicating the current state of the object. The server may also have a 

RtdbServerRegistry data Structure 246 containing data about the machine hosting the 
Rtdb server including the MachineName variable indicating the name of the machine 
hosting the Rtdb server, the MachinelD variable indicating the logical address, such as 
TCP/IP, of the machine, and the hEnsRtdb variable indicating the Rtdb handle for the 

20 machine. Thus, using this data structure, the real-time retrieval and dissemination 
system may uniquely identify and address each server and points. 
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While the foregoing has been with reference to a particular embodiment of the 
invention, it will be appreciated by those skilled in the art that changes in this 
embodiment may be made without departing from the principles and spirit of the 
invention, the scope of which is defined by the appended claims. 
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Claims : 



1 LA system for managing the facilities and the energy consumption of an 

2 enterprise of an entity, the enterprise comprising one or more geographically dispersed 

3 facilities and buildings, each building and facility having one or more devices which 

4 operate and consume energy, the system comprising: 

5 means for gathering information about the energy consumption and the 

6 operation of each device; 

7 an energy and facility management apparatus for controlling the facilities, 

8 buildings and devices in the geographically dispersed enterprise based on the energy 

9 consumption and operating information for each device, the energy management 

10 apparatus comprising means for communicating the energy consumption and operating 

1 1 data in real-time between the devices, the facilities and buildings and the energy and 

12 facility management apparatus; and 

13 a user interface for requesting energy consumption and operation data about 

14 one or more devices, facilities or buildings and for viewing the energy consumption 

15 and operation data about a predetermined portion of the enterprise. 

1 2. The system of Claim 1 , wherein the gathering means further comprises 

2 a gateway device connected to one or more of the devices for gathering energy 

3 consumption and operation data about the device and for converting the energy 

34 



WO 00/17984 



PCT7US99/21787 



4 consumption and operation data from a device format to a standard format and wherein 

5 the energy and facility management apparatus further comprises a server for processing 

6 the standardized energy consumption and operation data about the devices from the 

7 gateway to generate energy consumption management and facility management data, a 

8 plurality of user interfaces connected to the server, each user interface requesting data 

9 about one or more devices in the physical plant, and a concentrator connected to one or 

1 0 more of the user interfaces for interfacing between the user interfaces and the server, 

1 1 the concentrator comprising means for registering requests for data from a particular 

12 device by a particular client application, means for combining requests for data from 

13 the same device into a single data request from the server in order to reduce the amount 

14 of data requests to the server. 

1 3. The system of Claim 1 further comprising means for generating a 

2 representation of a particular selected facility in the enterprise based on the real-time 

3 energy consumption and operation data so that a user visually navigates through each 

4 facility. 

1 4. The system of Claim 3, wherein the generating means comprises a two- 

2 dimensional navigator. 
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1 5. The system of Claim 3, wherein the generating means comprises a 

2 three-dimensional navigator. 

1 6. The system of Claim 1 further comprising means for generating facility 

2 management data based on the energy consumption and operation data. 



1 7. The system of Claim 6 further comprising means for managing alarm 

2 signals generated by the facility manager and the energy manager in order to alert the 

3 user of the apparatus to alarm conditions in the geographically dispersed enterprise. 

1 8. A method for managing the facilities and the energy consumption of an 

2 enterprise of an entity, the enterprise comprising one or more geographically dispersed 

3 facilities and buildings, each building and facility having one or more devices which 

4 operate and consume energy, the method comprising: 

5 gathering information about the energy consumption and the operation of each 

6 device; 

7 controlling the facilities, buildings and devices in the geographically dispersed 

8 enterprise based on the energy consumption and operating information for each device 

9 using an energy and facility management apparatus comprising communicating the 
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10 energy consumption and operating data in real-time between the devices, the facilities 

1 1 and buildings and the energy and facility management apparatus; 

12 requesting energy consumption and operation data about one or more devices, 

1 3 facilities or buildings using a user interface; and 

14 viewing the energy consumption and operation data about a predetermined 

15 portion of the enterprise. 

1 9. The method of Claim 8, wherein the gathering further comprises 

2 gathering energy consumption and operation data about the device using a gateway 

3 device connected to one or more of the devices and converting the energy consumption 

4 and operation data from a device format to a standard format, and wherein the 

5 controlling further comprises processing the standardized energy consumption and 

6 operation data about the devices from the gateway using a server to generate energy 

7 consumption management and facility management data, requesting data about one or 

8 more devices in the physical plant by a user interface, and interfacing between the user 

9 interfaces and the server using a concentrator connected to one or more of the user 

10 interfaces comprising registering requests for data from a particular device by a 

1 1 particular client application and combining requests for data from the same device into 

12 a single data request from the server in order to reduce the amount of data requests to 

13 the server. 
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1 10. The method of Claim 8 further comprising generating a representation 

2 of a particular selected facility in the enterprise based on the real-time energy 

3 consumption and operation data so that a user visually navigates through each facility. 



1 11. The method of Claim 10, wherein the generating comprises using a two- 

2 dimensional navigator. 

1 12. The method of Claim 10, wherein the generating comprises using a 

2 three-dimensional navigator. 

1 13. The method of Claim 8 further comprising generating facility 

2 management data based on the energy consumption and operation data. 



1 14. The method of Claim 13 further comprising managing alarm signals 

2 generated by the facility manager and the energy manager in order to alert the user of 

3 the apparatus to alarm conditions in the geographically dispersed enterprise. 

1 15. A system for communicating data in real-time between an energy and 

2 facility management system and one or more devices of an enterprise which consume 

3 energy, the system comprising: 
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4 a device interface connected to the one or more of the devices for gathering 

5 real-time energy consumption data and operational data about the one or more devices 

6 connected to the device interface; 

7 a server connected to the device interface for storing the energy consumption 

8 and operation data for each device in the enterprise into a database, the energy 

9 consumption and operation data for each device being identified by a unique device 

10 address; 

11 a plurality of client applications, each client application requesting to receive 

12 energy consumption and operational data about one or more devices in the enterprise 

1 3 from the server; and 

14 a concentrator connected between the server and the one or more client 

15 applications, the concentrator comprising means for analyzing the requests for data 

16 from the client applications, means for combining requests for energy consumption and 

17 operation data about a particular device into a single combined request, means for 

1 8 communicating the single combined request to the server, and means for routing the 

19 energy consumption and operating data about the particular device received from the 

20 server to each client application which requests the energy consumption and operation 

21 data about that particular device. 
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1 16. The system of Claim 15 further comprising means for generating a 

2 representation of a particular selected facility in the enterprise based on the real-time 

3 energy consumption and operation data so that a user visually navigates through each 

4 facility. 

1 17. The system of Claim 16, wherein the generating means comprises a 

2 two-dimensional navigator. 

1 18. The system of Claim 16, wherein the generating means comprises a 

2 three-dimensional navigator. 

1 19. The system of Claim 15 further comprising means for generating 

2 facility management data based on the energy consumption and operation data. 

1 20. The system of Claim 19 further comprising means for managing alarm 

2 signals generated by the facility manager and the energy manager in order to alert the 

3 user of the apparatus to alarm conditions in the geographically dispersed enterprise. 
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1 2 1 . A system for communicating data in real-time between an energy and 

2 facility management system and one or more devices of an enterprise which consume 

3 energy, the system comprising: 

4 a device interface connected to the one or more of the devices comprising 

5 means for gathering real-time energy consumption data and operational data about the 

6 one or more devices connected to the device interface and means for storing the real- 

7 time energy consumption data and operational data into a database object; 

8 a server connected to the device interface for storing the energy consumption 

9 and operation data object for each device in the enterprise into a database, the energy 

10 consumption and operation data for each device being identified by a unique device 

11 object address; 

12 a plurality of client applications, each client application requesting to receive 

1 3 energy consumption and operational data about one or more devices in the enterprise 

14 from the server, each client application having a unique client address; and 

15 a concentrator connected between the server and the one or more client 

16 applications, the concentrator comprising means for analyzing the requests for data 

17 from the client applications, means for combining requests for energy consumption and 

1 8 operation data about a particular device into a single combined request, means for 

19 communicating the single combined request to the server, and means for routing the 

20 energy consumption and operating data about the particular device received from the 
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server based on the unique client addresses to each client application which requests 
the energy consumption and operation data about that particular device. 
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